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Amendments to the Claims: 

This listing of claims will replace all prior versions, and listings, of claims in the 
application: 

Listing of Claims: 

1 . (Previously Presented) A method of selecting a server to represent a virtual 
server hosted by a plurality of servers, comprising: 

providing, by a load balancer not associated with the virtual server, values, for one or 
more parameters, of two or more paths, each path defined between a point in a vicinity of a client 
accessing the vutual server and one of the plurality of servers representing the viitual server; and 

selecting a server to provide data for the client, responsive to the values of the one or 
more parameters, 

wherein the load balancer comprises a client-controlled load balancer that directly selects 
said one of the plurality of servers representing the virtual server based on said one or more 
parameters. 

2. (Original) A method according to claim 1 , wherein the load balancer and the 
client are in the same metropolitan area. 

3 . (Currently Amended) A method accordmg to claun 1 , wherein the chent- 
controlled load balancer aad rresides between t he client are in the same local area notwor k and the 
virtual server . 

4. (Original) A method according to claim 1, wherein the one or more parameters 
comprise at least one of a jitter, a round trip delay or a hop count. 

5 . (Previously Presented) A method according to clarai 1 , wherein the one or more 
parameters comprise a cost of communication. 
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6. (Previously Presented) A method according to claim 1, wherein selecting the 
server comprises selecting, by the chent-controUed load balancer, responsive to receivmg 
identification of a virtual server requested by the client. 

7. (Previously Presented) A method according to claim 6, wherein selecting the 
server comprises selecting, by the client-controlled load balancer, responsive to receiving a 
cormection establishment request from the client. 

8. (Original) A method according to claun 6, wherein providing the values for the 
one or more parameters comprises measuring at least one of the parameters. 

9. (Original) A method according to claim 8, wherein measuring at least one of the 
parameters, for at least one of the paths, is performed before receiving the connection 
establishment request. 

1 0. (Original) A method according to claim 8, wherein measuring at least one of the 
parameters for at least one of the paths is performed after receiving the connection establishment 
request. 

1 1 . (Original) A method according to claim 1 , further comprising changing the 
destination IP address of packets received by the load balancer from the cUent, to an IP address 
of the selected server. 

12. (Original) A method accordmg to claun 1, further comprising changing the 
source IP address of packets received by the load balancer fi*om the selected server. 

1 3 . (Original) A method according to claim 1 , further comprising transmitting an IP 
address of the selected server to the client. 
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14. (Original) A method according to claim 13, wherein transmitting the IP address 
of the selected server to the cUent comprises transmitting a DNS response. 

1 5 . (Original) A method according to claim 1 , wherein ones of the plurality of servers 
are located in different geographical regions. 

16. (Original) A method according to claim 1 , wherein selecting a server to provide 
data for the client comprises selecting, by the load balancer, a second load balancer which is to 
perform the server selection and selecting, by the second load balancer, a server to provide data 
for the client. 

1 7. (Original) A method according to claim 1 , wherein the virtual server hosts a web 

site. 

1 8. (Original) A method according to claim 1 , wherein selecting a server to provide 
data for the client comprises selecting a server which minimizes a function of the one or more 
parameters. 

1 9. (Original) A method according to claim 1 8, wherein selecting a server to provide 
data comprises choosing a fimction of the one or more parameters to be minimized and selecting 
a server which minimizes the chosen function. 

20. (Original) A method according to claim 19, wherein the function is chosen 
responsive to a protocol with which the virtual server is accessed. 

2 1 . (Original) A method according to claim 1 9, wherein the function is chosen 
responsive to the virtual server accessed. 

22. (Original) A method according to claim 19, wherein the ftmction is chosen 
responsive to an attribute of the client. 
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23 . (Original) A method according to claim 1 9, wherein the function is chosen 
responsive to the time of the selection. 

24. (Previously Presented) A method of selecting a server to be accessed, comprising: 
receiving, by a load balancer, a message relating to a virtual server, hosted by a plurality 

of servers, and to a client desiring to receive data from the virtual server; and 

selectuig, by the load balancer, one of the plurality of servers to provide data to the server, 

wherein the load balancer is closer to the client than to the selected server, and 

wherein the load balancer comprises a client-controlled load balancer that directly selects 

said one of the plurality of servers representmg the virtual server based on said one or more 

parameters. 

25. (Original) A method according to claim 24, wherein the load balancer is closer to 
the client than to any of the plurality of servers hosting the virtual server. 

26. (Original) A method according to claim 24, wherem the load balancer is in the 
same metropoUtan area as the client. 

27. (Currently Amended) A method according to claim 24, wherein the client- 
controlled load balancer resides between i s in the same local area network as t he clien t and the 
virtual server . 

28. (Original) A method according to claim 24, wherein tlie load balancer is not 
associated with the virtual server. 

29. (Original) A method according to claim 24, wherein the load balancer is under 
control of a system manager of the client. 
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30. (Original) A method according to claim 24, wherein receiving the message 
comprises receiving a DNS query message. 

3 1 . (Original) A method according to claim 24, wherein receiving the message 
comprises receiving from a DNS server. 

32. (Original) A method according to claim 24, wherein receivmg the message 
comprises receiving a connection estabUshment request directed to the virtual server. 

33 . (Origmal) A method according to claim 24, wherein receiving the message 
comprises receiving a message directed to the load balancer. 

34. (Previously Presented) A method according to claim 24, wherein selecting one of 
the servers comprises selecting a server which has a lowest cost path to the load balancer. 

35. (Original) A method accordmg to claim 24, whereui selecting one of the servers 
comprises selectmg a server which has a lowest delay path or a highest packet size path to the 
load balancer. 

36. (Original) A method according to claim 24, wherem the load balancer is 
geographically closer to the client than to the selected server. 

37. (Previously Presented) A method of selecting a server to be accessed, comprising: 
receiving, by a load balancer, a message relating to a virtual server, hosted by a plurality 

of servers, and to a client desiring to receive data from the virtual server; and 

selecting, by the load balancer, one of the plurality of servers to provide data to the client, 
at least partially responsive to the cost of communications between the cUent and one or more of 
the plurality of servers, 



-6- 



Application No. 10/072,364 



wherein the load balancer comprises a client-controlled load balancer that directly selects 
said one of the plurality of servers representing the virtual server based on said one or more 
parameters. 

38. (Previously Presented) A method according to claim 37, wherein selecting one of 
the servers comprises selecting a server under a constraint that a lowest cost cHent 
communication connection is used in connecting to the server. 

39. (Previously Presented) A method according to claim 37, wherein selecting one of 
the sei-vers comprises selecting a sei-ver which minimizes a weighted sum of communication 
costs to the server and at least one other route related parameter. 

40. (Previously Presented) A method according to claim 39, wherein selecting one of 
the servers comprises selecting a server which minimizes a weighted sum of the communication 
costs to the server and the round trip delay to the server. 

41 . (Previously Presented) A load balancer, comprising: 

an mterface adapted to receive server access messages from clients; and 

a processor adapted to determine, for at least one of the messages, whether the message 

requires load balancing responsive to at least one attribute different from the identity of the 

server referenced by the message, and to select for at least one message determined to require 

load balancing, a server to service the cKent, 

wherein the processor comprises a client-controlled processor that directly selects the 

server to service the client based on the at least one attribute. 

42. (Original) A load balancer according to claim 4 1 , wherein the at least one 
attribute comprises the time at which the message is received at the interface. 

43 . (Original) A load balancer according to claim 41 , wherein the at least one 
atfribute comprises the identity of the client. 
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44. (Origtrial) A load balancer according to claim 41 , wherein the at least one 
attribute comprises a protocol to govern the communication with the server. 

45. (Original) A load balancer according to claim 41, further comprising a packet 
changing unit adapted to change the contents of at least one field of packets belonging to 
connections for which load balancing was performed. 

46. (Original) A load balancer according to claim 41 , wherein the packet changing 
unit is adapted to change packets in accordance with half NAT or full NAT procedures. 

47. (Previously Presented) A method of selecting a server to be accessed, comprising: 
receiving, by a load balancer, a message relating to a virtual server, hosted by a pluraUty 

of servers, and to a client desiring to receive data from the virtual server; 

choosing a function from a plurality of predetermined functions utilized by the load 
balancer for selecting servers, responsive to the received message; and 

selecting, by the load balancer, one of the plurality of servers tliat minimizes or 
maximizes the chosen function, to provide data to the client, 

wherein the load balancer comprises a client-controlled load balancer that directly selects 
said one of the plurality of servers representing the virtual server that minimizes or maximizes 
the chosen function. 

48. (Original) A method according to claim 47, wherein choosing the function 
comprises choosing responsive to an identity of the client. 

49. (Original) A method according to claim 47, wherein choosing the function 
comprises choosing responsive to a time at which the message is received. 

50. (Original) A method accordmg to claim 47, wherein at least two of the 
predetermined functions depend on different groups of one or more parameters. 
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51. (Original) A method according to claim 47, wherein at least two of the 
predetermined functions depend on the same parameters but give different weight to one or more 
of the parameters on wliich they depend. 
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